package com.taoz.mianshiwa.satoken;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

import cn.dev33.satoken.stp.StpUtil;
import com.taoz.mianshiwa.constant.UserConstant;
import com.taoz.mianshiwa.model.entity.User;
import org.springframework.stereotype.Component;
import cn.dev33.satoken.stp.StpInterface;

/**
 *    自定义权限验证接口扩展 
 */
@Component    // 保证此类被springboot扫描，完成sa-token的自定义权限验证扩展 
public class StpInterfaceImpl implements StpInterface {

    /**
     * 返回一个账号所拥有的权限码集合 
     */
    @Override
    public List<String> getPermissionList(Object loginId, String loginKey) {
        return new ArrayList<>();
    }

    /**
     * 返回一个账号所拥有的角色标识集合 (权限与角色可分开校验)
     */
    @Override
    public List<String> getRoleList(Object loginId, String loginKey) {
        User user = (User) StpUtil.getSessionByLoginId(loginId).get(UserConstant.USER_LOGIN_STATE);
        return Collections.singletonList(user.getUserRole());
    }

}
